java递归算法(1加到100&换汽水)

老师上课给了两个题目让我们自己写


- 不用循环,1加到100

-`public static int sum(int num){
        if(num==1){
            return 1;
        }
        if(num>1){
            return num+sum(num-1);
        }
        return 0;
    }`

- 换汽水

一共20元,1元一瓶汽水,三个瓶盖换一瓶新汽水,两个空瓶换一瓶汽水。注:不能算赊汽水啊,赖皮;

/**shengGai是剩下的Gai子,shengPing是剩下的空Ping子*/
 public static int sum(int drink,int shengGai,int shengPing){   //静态方法,放在main在的类里
        int ping=drink+shengPing;
        int gai=drink+shengGai;
        if(ping/2+gai/3==0){
            return drink;
        }
        return drink+sum(ping/2+gai/3,gai%3,ping%2);        
    }

下面是测试的完整代码,复制记得改类名>.<
一开始赋值可以是20,0,0,意思是买了20瓶,0个剩盖子,0个剩空瓶子 输出结果是113 百度过别人的答案是对的。

public class Test {
    public static void main(String[] args) {
        System.out.println(sum(20,0,0));
    }
    public static int sum(int drink,int shengGai,int shengPing){    
        int ping=drink+shengPing;
        int gai=drink+shengGai;
        if(ping/2+gai/3==0){
            return drink;
        }
        return drink+sum(ping/2+gai/3,gai%3,ping%2);

    }
}

瞎bb环节

老师上课讲了关于文件删除(File类),在删除目录(文件夹)时,有个先提条件是,目录下没有文件才能删除,所以在多个目录和文件互相包含的时候,就要反复调用对目录和文件的判定依据删除程序。
老师借这个机会给我们讲了递归算法,但老师说了递归在开发过程中很少用到,而且是尽量去避免去用,因为很浪费,了解就行。
如果想试一下文件删除递归,可以找文档文件删除主要涉及File类 和file下面的方法File listFiles(),boolean delete(),boolean isDirectory();


互勉

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值